草庐IT

Rust 生命周期

全部标签

performance - 为什么在 Go 中交换 []float64 的元素比在 Rust 中交换 Vec<f64> 的元素更快?

我有两个(等效的?)程序,一个在Go中,另一个在Rust中。平均执行时间为:开始~169ms使用rust~201ms开始packagemainimport("fmt""time")funcmain(){work:=[]float64{0.00,1.00}start:=time.Now()fori:=0;i使用rust我用--release编译usestd::time::Instant;fnmain(){letmutwork:Vec=Vec::new();work.push(0.00);work.push(1.00);letnow=Instant::now();for_xin1..100

Go vs Rust 垃圾收集器性能和类型

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭3年前。Improvethisquestion我阅读了一些关于Go的GC的堆栈溢出信息。Go垃圾收集器中的栈和堆模型我想知道如果一个变量需要在Go中定义在堆或栈中,然后GC要收集它,使用什么算法?如果我们假设在具有GC的语言中,堆更高效,那么Rust又如何?与Go相比,Rust如何处理这个问题?特别是关于Go中的引用计数器,我们在大多数时候别无选择地询问编译器,但这样的工具存在并且它以自己的方式完成它的工作!我读过这个:Stackvsheap

ruby - Rust 数学错误

我在Rust中有以下代码:fnmain(){letmutsum=0is;foriin(0is..100000000is){sum=sum+i;}println!("{}",sum);}结果,我有4999999950000000但是,当我尝试使用Golang和Ruby检查此代码时-我看到了另一个结果golang版本:packagemainimport"fmt"funcmain(){varsum=0fori:=1;iruby版本:@sum=0(1...99999999).eachdo|i|@sum+=iendputs@sumRuby和Golang的结果都是4999999850000001P

arrays - 在 GoLang 和 Rust 中初始化字符串数组

我想初始化一个二维数组,其中内部数组的每个成员都包含一个由1000个x组成的字符串。像这样的东西:vardata=[num_rows][num_cols]string("x....x(upto1000)")但是所有的谷歌搜索都是徒劳的。在C++中,我可以实现类似的事情:vector>data(num_rows,vector(num_cols,string("x",1000)));在Ruby中是这样的:Array.new(num_rows){Array.new(num_cols){"x"*1000}}想在go中实现类似的结果,但我找不到任何文档来填充字符串和初始化二维数组。另请注意,我想

go - 如何解决导入周期不允许的问题,尽管我正在使用界面?

有三个结构:A(packagea),B(packageb),C(packagec)。B想要使用C的功能,C想要使用B的功能。A有B和C实例,所以B可以访问C的功能>通过A反之亦然。我使用了在另一个packagei中声明的接口(interface)Ageter,它的函数声明为GetA()*a.A现在我在B和C中使用这个接口(interface)Ageter,通过它我得到A的实例和访问功能C和B。packageaimport("fmt""basics/importCycleIssue/issueFix/b""basics/importCycleIssue/issueFix/c")typeA

go - 类型导入周期

看了stackoverflow上的问题和其他网站的文章,还是无法解决问题。这是我的代码:packageroutingimport("net/http""bitbucket.org/codictive/ise/components/user")//Routedefinesacomponentroutestructure.typeRoutestruct{PathstringNamestringMethodstringDescriptionstringHandlerfunc(whttp.ResponseWriter,r*http.Request,dataTemplateData)}//Tem

go - 克服 Go 中不允许的导入周期

我理解这个问题,根据答案here,但是,我真的可以使用帮助或更详细的代码解释来说明它是如何克服的。我的情况是这样的:我曾经将模型和Controller分开,在我的模型包中我有一个包含所有模型函数接口(interface)的datastore.go文件:packagemodelstypeDSDatabaseinterface{CreateUser(ctxcontext.Context,usernamestring,password[]byte)(*datastore.Key,error)//Moremodelfunctions}typedatastoreDBstruct{client*d

Golang 导入周期挑战

我在我的go代码中遇到循环依赖(不允许导入循环)的问题,并且不确定解决它的最佳方法。我认为我对golang接口(interface)缺乏了解可能会影响我看清前进方向的能力。我的问题-我有两个包裹:Event-Event主要是“父项”,会多次调用锻炼包Workout-在一种情况下,我需要调用事件包,这会产生循环依赖,因为Event已经消耗了Workout允许Workout在事件域中调用函数(而不是对象上的方法)的最佳方法是什么?下面是我的简化代码,以帮助提供一些上下文//workoutpackage//Thisisaprivatefunctionontheworkoutpackageth

go - 在 Go 中测试生命周期。是否可以在不重复代码的情况下添加拆卸方法?

一个月前我开始使用Go。我来自java/kotlin背景,我想了解是否有可能实现我在这些语言中所做的一些相同的事情,即使是在Go中也是如此。我目前的问题是这个。我有一组集成测试用例,我需要在其中初始化一些东西然后清理资源:我相信这是一个常见的用例。如果可能的话,这是我想要实现的一些伪代码:foreachtest{initresourcesruntest{inittestresourcesexecutemethodundertestassert}cleanresources}目前,我可以尝试的是这种方法:funcTestMain(m*testing.M){setup()code:=m.R

用Rust实现区块链 - 6 点对点网络(P2P)

截止到目前,我们在单机上实现了区块链的几乎所有关键特性:随机生成的地址、安全、持久化、工作量证明、UTXO交易。接下来我们将使用rust-libp2p库来实现区块链的p2p网络。P2P网络P2P网络拓扑结构有很多种,有些是中心化拓扑,有些是半中心化拓扑,有些是全分布式拓扑结构。区块链网络中的全节点就是全分布式拓扑结构,即去中心化的,端到端的网络,节点直接连接到其他节点,它的拓扑结构是扁平的。SPV节点(简单支付验证节点),随机选择一个全节点进行连接,依赖这个全节点来获取数据,更接近半中心化的拓扑结构。在这里我们先实现全节点,后面再逐渐完善矿工节点和SPV节点,在本地网络中通过MDNS做节点发现